package Text18;

import java.util.*;

public class Main {
    //    第一行输入整数 N。
//    第二行是 N个空格分隔的整数，H(1),H(2),…,H(N)代表建筑物的高度。
    static final int N = 100010;
    static int n;
    static int[] h = new int[N];
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        n = scanner.nextInt();
        for (int i = 0; i <n ; i++) {
            h[i]=scanner.nextInt();
        }
        int l=1;
        int r=100000;
        while (l<r){
            int mid=l+r>>1;
            if(check(mid)){
                r=mid;
            }else {
                l=mid+1;
            }
        }
        System.out.println(l);
    }

    private static boolean check(int e) {
        for (int i = 0; i <n ; i++) {
            e=2*e-h[i];
            if(e<0){
                return false;
            }
            if(e>=100000){
                return true;
            }
        }
        return true;
    }
}
